CLAIMS 



I claim: 

1. A method for automatic generation of join 
graphs foA relational database queries, comprising: 

(k) receiving an input list of tables including 
attributes oA interest for a database query; 

(b) marking instances of tables of said input list 
having single occurrences in an hierarchical representation 
of a database schama, and marking ancestors of said 
instances of tablek according to said hierarchical 
representation; \ 

(c) markingVunmarked instances of multi- 
dimensional tables of said input list closest to marked 
instances, marking unmanked ancestors of said unmarked 
instances of said multi-dVmensional tables according to said 
hierarchical representation, and marking unmarked instances 
of one-dimensional tables t\at reference said multi- 
dimensional tables and have said unmarked instances of said 
multi-dimensional tables as parents according to said 
hierarchical representation; \ 

(d) marking unmarked instances of one-dimensional 
tables of said list of tables closest to marked instances, 
and marking unmarked ancestors of sVid unmarked instances of 
said one-dimensional tables according to said hierarchical 
representation; and \ 

(e) generating a join graph corresponding to said 
input list of tables from said marked instances in said 
hierarchical representation. \ 
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2. The method according to claim 1, wherein said 
(b) comprises: 

(bl) selecting a table of said input list; 

)2) determining whether a number of instances of 
said table in an hierarchical representation of a database 
schema is greater than one; 

(b3)\if said number of instances of said table is 
not greater than one, then marking an instance of said table 
in said hierarchical representation and all unmarked 
instances of ancestor tables to said table according to said 
hierarchical representation; and 

(b4) repeating (bl) to (b3) until a last table in 
said input list is processed. 



yy 
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3. The methoc\according to claim 1, wherein said 
(b) comprises: 

(b5) selecting a t^ble having a table name from 
said input list; 

(b6) determining whe&ier a number of dimensions of 
said table is greater than one according to a database 
schema; 

(b7) if said number of dimensions of said table is 
greater than one, then adding said uable name to a multi- 
dimensional list of tables, and if saad number of dimensions 
of said table is not greater than one ,\ then adding said 
table name to a one-dimensional list oA tables; and 

(b8) repeating (b5) to (b7) un^il a last table in 
said input list is processed. 
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\ 4. The method according to claim 1, wherein said 

(b) comprises: 

\ (bl) selecting a table having a table name from 
said inpVt list; 

Vb2) determining whether a number of instances of 
said table Vn an hierarchical representation of a database 
schema is one; 

(b3\ if said number of instances of said table is 
one, then markVng an instance of said table in said 
hierarchical representation and all unmarked instances of 
ancestor tables Yo said table according to said hierarchical 
representation; \ 

(b4) if asaid number of instances of said table is 
greater than one, traen determining whether a number of 
dimensions of said table is greater than one according to a 
database schema; \ 

(b5) if said\number of dimensions of said table is 
greater than one, then adding said table name to a multi- 
dimensional list of tabl&s, and if said number of dimensions 
of said table is not greater than one, then adding said 
table name to a one-dimensional list of tables; and 

(b6) repeating (bi) to (b5) for all tables in said 
input list. \ 

5. The method according to claim 3, wherein said 

(c) comprises: \ 

(cl) selecting a multi-Mimensional table from said 
multi-dimensional list; \ 

(c2) if an instance of sa\d multi-dimensional 
table has been marked in said hierarchical representation, 
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then\selecting another multi-dimensional table from said 
multi\dimensional list; 

(c3) if an instance of said multi-dimensional 
table ha^vnot been marked in said hierarchical 
representation, then finding an instance of said multi- 
dimensional\table that is a closest child in relationship to 
a marked instance in said hierarchical representation; 

(c4)\marking said found instance of said multi- 
dimensional tab\e and instances of all unmarked ancestors of 
said found instance of said multi-dimensional table 
according to said uii erarc hical representation; 

(c5) generating a dimensions list for said multi- 
dimensional table ; 

(c6) processing said dimensions list; and 

(c7) repeating (cl) to (c6) until a last table in 
said multi-dimensional Mst is processed. 



6. The method according to claim 5, wherein said 
(c5) comprises referring to\ a database schema to determine 
all reference tables to saidV multi-dimensional table, and 
including all said reference cables except a parent of said 
multi-dimensional table accorc^_ng to said hierarchical 
representation. 



7. The method according to claim 6, wherein said 
(c6) comprises: 

(c61) selecting a referenda table from said 
dimensions list; 
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\ (c62) if a table name of said reference table is 
not in\said one-dimensional list, then selecting another 
reference table from said dimensions list; 

\ (c63) if said table name of said reference table 
is in saioVone-dimensional list, then marking an instance of 
said reference table in said hierarchical representation 
having said current multi-dimensional table as its parent; 

(c64a removing said table name from said one- 
dimensional lisA; and 

(c65) repeating (c61) to (c64) until a last 
reference table in\ said dimensions list has been processed. 

8. The method according to claim 1, wherein said 
(d) comprises: \ 

(dl) selecting a one-dimensional table from said 
one-dimensional list; \ 

(d2) if an instance of said one-dimensional table 
has been marked in said hierarchical representation, then 
selecting another one-dimensional table from said one- 
dimensional list; \ 

(d3) if an instance of said one-dimensional table 
has not been marked in said hierarchical representation, 
then finding an instance of said one-dimensional table that 
is a closest child in relationship to a marked instance in 
said hierarchical representation 

(d4) marking said founcft instance of said one- 
dimensional table and instances on all unmarked ancestors of 
said found instance of said one-dimensional table according 
to said hierarchical representation* 
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fti5) repeating (dl) to (d4) until a last one- 
dimensional \table in said one-dimensional list is processed. 
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